package  main.java.leetcode.editor.cn;
//2023-07-25 14:20:33
//珠玑妙算游戏（the game of master mind）的玩法如下。 
// 计算机有4个槽，每个槽放一个球，颜色可能是红色（R）、黄色（Y）、绿色（G）或蓝色（B）。例如，计算机可能有RGGB 4种（槽1为红色，槽2、3为绿色，槽
//4为蓝色）。作为用户，你试图猜出颜色组合。打个比方，你可能会猜YRGB。要是猜对某个槽的颜色，则算一次“猜中”；要是只猜对颜色但槽位猜错了，则算一次“伪猜中”。
//注意，“猜中”不能算入“伪猜中”。 
// 给定一种颜色组合solution和一个猜测guess，编写一个方法，返回猜中和伪猜中的次数answer，其中answer[0]为猜中的次数，answer[
//1]为伪猜中的次数。 
// 示例： 
// 输入： solution="RGBY",guess="GGRR"
//输出： [1,1]
//解释： 猜中1次，伪猜中1次。
// 
// 提示： 
// 
// len(solution) = len(guess) = 4 
// solution和guess仅包含"R","G","B","Y"这4种字符 
// 
// Related Topics 哈希表 字符串 计数 👍 53 👎 0

import java.util.HashMap;
import java.util.Map;

class MasterMindLcci {
    public static void main(String[] args) {
        //创建该题目的对象方便调用
        Solution solution = new MasterMindLcci().new Solution();
        solution.masterMind("GGBB","RBYB");
    }
    //leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public int[] masterMind(String solution, String guess) {
        Map<Character,Integer> map = new HashMap<>();
        char[] guesss = guess.toCharArray();
        int yes = 0;
        int no = 0;
        for(int i = 0;i<solution.length();i++){
            if(solution.charAt(i) == guess.charAt(i)){
                yes++;
                guesss[i] = 'J';
            }else {
                map.put(solution.charAt(i),map.getOrDefault(solution.charAt(i),0)+1);
            }
        }
        for(int i = 0;i<solution.length();i++){
            if(map.containsKey(guesss[i]) && map.get(guesss[i]) != 0){
                map.put(guesss[i],map.get(guesss[i])-1);
                no++;
            }
        }
        return new int[]{yes,no};
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}
